# **GHOST Synth Final Presentation**

Sriharsha H S Marco Merlini Mathew Hildebrand Austin Liolli

### **Table of Contents**

- Project Overview
- Design Environment
- Verification and Testing
- HLS in GHOST Synth
  - HLS Techniques
  - Pros and Cons of Using HLS vs. HDL
  - Impressions
- Physical Demonstration



## **Overview and Requirements**

- SoC-Based Synthesizer
- Multiple voices
- Layer effects with crossbar
- Configure over AXI Lite bus
- I2S Converter sends samples to DAC



# **Design Environment**

- Vivado HLS 2017.2 for FPGA Image
- Petalinux toolchain 2016.2
- Vivado SDK 2017.2
- Revision control through Git







https://github.com/mathild7/ECE1373 GhostSynth.git

## **Design Infrastructure**

- AVNET Zynq Mini ITX
- ADAU1761 audio CODEC
- 100MHz & 12.288MHz clocks
- FPGA Shell for easy integration





### **Verification and Testing**

- Incremental inclusion into bitstream
- I2S core, PLL and ATG modules tested first
  - Verify clocking and resets to shell modules
  - Verify audio CODEC can produce audio
- Modules verified using Csim then in Vivado



### **HLS in GHOST Synth**

#### Sources

- O Saw Wave Generator
- o FM Synthesizer
- O White Noise Generator

#### • Effects

- O Digital Filter
- o Echo/Reverb
- o Mixer
- O Envelope Generator
- o Tremolo
- o Compressor
- o Vibrato

#### • Misc

- o Convertor
- o Latcher





# **Module Interfacing**

- ap\_ctrl\_none
- Blocking reads/writes
- Crossbars



## **Pros and Cons of Using HLS vs. HDL**

| Pros                                                                                                                                          | Cons                                                                                                                                          |
|-----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Easily manage interface protocols</li> <li>HLS manages wires for AXI stream interface</li> <li>Natural blocking behaviour</li> </ul> | <ul> <li>Weak converting program logic and calculations to efficient hardware</li> <li>Lack of flexibility in synthesized hardware</li> </ul> |

- When performance is not critical
  - HLS is 2x faster
- Otherwise
  - About equal

### **Overall Impressions of HLS**

- Easy to use, hard to master
  - If performance is not limiting, implementation is straightforward
  - Significant effort for optimizations
- Information present, but hard to locate

### **Demonstration**

### **Thank You!**

**Questions?**